使用idea搭建Tomcat源码运行环境

我自己编译的源码路径:https://github.com/LoveWK/myTomcat.git

1.首先从官网上下载Tomcat的源码包

 

 

 2.下载完成后解压到本地文件

 3.创建一个Tomcat的实例运行文件catalina-home

 4.在Catalina-home文件中创建这几个文件夹

  除了conf目录其他都是可选的,webapps用于我们应用默认的部署目录,work logs是启动Tomcat自动生成的,其结构跟我们下载的二进制Tomcat程序是一样的.

  5.创建一个pom.xml文件,用来配置maven依赖,<module>标签里的内容就是我们解压的Tomcat源码文件的文件名

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <project xmlns="http://maven.apache.org/POM/4.0.0"
 3          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 4          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 5 
 6     <modelVersion>4.0.0</modelVersion>
 7     <groupId>gxf</groupId>    
 8     <artifactId>apache-tomcat-8</artifactId>    
 9     <name>apache-tomcat-8-source</name>    
10     <version>1.0</version>    
11     <packaging>pom</packaging> 
12     <modules>    
13         <module>apache-tomcat-8.5.56-src</module>    
14     </modules>    
15 </project>

6.在Tomcat源码文件中创建一个pom.xml文件,用来引入依赖。

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <project xmlns="http://maven.apache.org/POM/4.0.0"
 3          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 4          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 5 
 6     <modelVersion>4.0.0</modelVersion>
 7     <groupId>org.apache.tomcat</groupId>
 8     <artifactId>Tomcat8.5.56</artifactId>
 9     <name>Tomcat8.5.56</name>
10     <version>8.5</version>
11 
12 
13     <build>    
14         <finalName>Tomcat8.0</finalName>    
15         <sourceDirectory>java</sourceDirectory>    
16         <testSourceDirectory>test</testSourceDirectory>    
17         <resources>    
18             <resource>    
19                 <directory>java</directory>    
20             </resource>    
21         </resources>    
22         <testResources>    
23             <testResource>    
24                 <directory>test</directory>    
25             </testResource>    
26         </testResources>    
27         <plugins>    
28             <plugin>    
29                 <groupId>org.apache.maven.plugins</groupId>    
30                 <artifactId>maven-compiler-plugin</artifactId>    
31                 <version>2.0.2</version>    
32     
33                 <configuration>    
34                     <encoding>UTF-8</encoding>    
35                     <source>1.8</source>    
36                     <target>1.8</target>    
37                 </configuration>    
38             </plugin>    
39         </plugins>    
40     </build>    
41 
42    <dependencies>  
43         <dependency>  
44             <groupId>org.easymock</groupId>  
45             <artifactId>easymock</artifactId>  
46             <version>3.5</version>  
47             <scope>test</scope>  
48         </dependency>  
49   
50         <dependency>    
51             <groupId>junit</groupId>    
52             <artifactId>junit</artifactId>    
53             <version>4.12</version>  
54             <scope>test</scope>    
55         </dependency>    
56         <dependency>    
57             <groupId>ant</groupId>    
58             <artifactId>ant</artifactId>    
59             <version>1.7.0</version>    
60         </dependency>    
61         <dependency>    
62             <groupId>wsdl4j</groupId>    
63             <artifactId>wsdl4j</artifactId>    
64             <version>1.6.2</version>    
65         </dependency>    
66         <dependency>    
67             <groupId>javax.xml</groupId>    
68             <artifactId>jaxrpc</artifactId>    
69             <version>1.1</version>    
70         </dependency>    
71         <dependency>    
72             <groupId>org.eclipse.jdt.core.compiler</groupId>    
73             <artifactId>ecj</artifactId>    
74             <version>4.6.1</version>  
75         </dependency>    
76     </dependencies>    
77 </project>

 

 7.开始使用maven构建项目

 

 

 8.等待idea将项目构建好

   在构建的过程当中,会出现如下图的错误,直接注释掉用到CookieFilter的行数即可。

 9.开始对项目进行配置

 

 

 

 

 

 

 配置启动参数:

-Dcatalina.home=catalina-home
-Dcatalina.base=catalina-home
-Djava.endorsed.dirs=catalina-home/endorsed
-Djava.io.tmpdir=catalina-home/temp
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
-Djava.util.logging.config.file=catalina-home/conf/logging.properties

 

 

 配置完成后,启动项目:

 注:解决tomcat日志输出乱码问题:

解决办法

VM option 增加启动参数-Duser.country=EN

其他方法

这位大哥直接debug到了tomca日志打印源码,进行了修改,NB!
https://blog.csdn.net/zhoutaoping1992/article/details/104751705

IDEA其他乱码修改办法记录

https://www.cnblogs.com/fanlinglong/p/6717515.html

 

 打开浏览器访问服务,发现报500错误

 

这个原因是因为我们直接启动org.apache.catalina.startup.Bootstrap的时候没有加载org.apache.jasper.servlet.JasperInitializer,从而无法编译JSP。这在Tomcat6/7是没有这个问题的。解决办法是:

打开文件:java/org/apache/catalina/startup/ContextConfig.java,找到webConfig()方法,在下面加上context.addServletContainerInitializer(new JasperInitializer(),null);即可。

 

 重新启动Tomcat,访问地址,发现访问成功:

 

posted @ 2020-06-16 00:18  WK_BlogYard  阅读(2373)  评论(1编辑  收藏  举报